Kalman-viterbi joint channel equalizer

ABSTRACT

In a channel equalizer applicable to a digital television receiver, a forward filter and a backward filter perform filtering to an input signal and a predetermined signal. A Viterbi decoder corrects errors during a transmission procedure in a blind mode. A training symbol storing block stores training symbols. An output signal of the Viterbi decoder and symbols are provided to the backward filter in accordance with a blind mode or a training mode. A Kalman gain is calculated in a Kalman gain calculating block and an error signal is calculated by comparing an equalized signal, symbols, and the output signal of the Viterbi decoder with one another. A tap coefficient is updated by using the calculated error signal and the Kalman gain.

BACKGROUND OF THE INVENTION

(a) Field of the Invention

The present invention relates to an equalizer and a control method of the equalizer which are used for improving performance in a receiver under a multi-path communication environment of indoor, portable, and mobile reception.

(b) Description of the Related Art

In the ATSC (Advanced Television Systems Committee) standard which has been adopted as a digital television broadcasting standard in North America, there is a problem in that transmission signals are distorted under an indoor and mobile communication environment due to variable channel and multi-path effects. This reduces reception performance in a receiver such as a digital television.

In a digital communication system, data transmission is performed in symbol units through a restricted frequency band width, and pulse energy of a symbol may be dispersed into neighboring symbol pulses due to a time dispersion effect. This induces interference in the neighboring symbols. In addition, transmitted data is affected by various kinds of channel distortions, caused by such effects as a multi-path effect, a frequency offset effect, a phase jitter effect, and so on. These effects induce ISI (Inter-Symbol Interference) which may affect neighboring symbols of a transmission symbol in a digital communication system. Therefore, the ISI becomes a barrier to obtaining desired data in a receiver. In addition, most communication channels require an adaptive equalizer which may update tap coefficients adaptively with respect to time variation, since the above described distortions are variable.

FIG. 1 illustrates a block diagram of a conventional VSB (vestigial sideband) signal receiving system. In FIG. 1, a tuner 100 receives an RF signal from an antenna and synchronizes the RF signal with a local oscillation signal to transform the RF signal into an IF signal; an NTSC removing filter 200 removes an NTSC component from the IF signal to prevent degradation of an HDTV due to the NTSC component; an equalizer 300 removes multi-path distortion generated in a transmission channel by equalizing an input signal; a phase tracer 400 removes phase noise from the equalized signal; a trellis decoder 500 performs trellis decoding with respect to an output signal of the phase tracer 400, and outputs the decoded signal; a data de-interleaver 600 performs reverse interleaving to the input signal; an RS decoder 700 performs Reed-Solomon decoding to the input signal so as to generate error-corrected bit streams; and a de-randomizer 800 provides the decoded signal into other elements of the receiving system.

In FIG. 2, a detailed configuration of an ATSC VSB equalizer is illustrated. The equalizer 300 basically uses an LMS algorithm. In FIG. 2, a front filter 301 and a rear filter 302 remove an inter-symbol interference component, which generates distortion, from a received signal. In case of a blind mode, a quantization block 303 compares the signal outputted from the filters 301 and 302 with a predetermined threshold value and outputs hard-decision data. A training symbol storing block 304 stores a training data symbol which is perceived in a transmitting system. The training symbol is fetched into the rear filter 302 and an error signal calculating block 306 in a training mode, and it is used for calculating errors of the equalized signal. In case of a blind mode, the output signal of the quantization block 303 and the equalized signal are used for calculating errors. A switching block 305 passes the equalized signal or training symbol therethrough in accordance with the two modes. The calculated error is outputted to a tap coefficient updating block 307.

The tap coefficient updating block 307 receives an error signal and input signal of the filter 301, and updates the tap coefficient by using an LMS algorithm. Such an updating method is as shown in the following Equation 1. C(n+1)=C(n)+μx(n)e(n)  [Equation 1]

In Equation 1, c(n) is a coefficient of a filter, x(n) is a received signal, e(n) is an error signal calculated in the error signal calculating block 306, and μ is a step size.

As such a channel equalizer, a DFE (decision feedback equalizer) is widely used in a digital television receiver. When a decision error is not generated in a quantization block of the DFE, noise amplification at output of the equalizer, which becomes a problem in a conventional linear equalizer, does not appear when a rear filter removes ISI due to a symbol determined previously. For this reason, the DFE is widely used in a receiving system. Therefore, it is important that a decision error is not generated at output of a quantization block, so the DFE can be used effectively. For attaining this technical point, a method for reducing decision error by inserting a training symbol at a constant period has been used in a digital communication system, while willingly accepting a reduction in data transmission efficiency. However, not enough training symbols are inserted in most cases. The conventional DFE does not have a rapid enough convergent speed to compensate for distortion of a received signal that is generated due to inter-channel interference under a highly distorted communication environment such as indoor reception, mobile reception, or in a communication environment producing ghost images such as a broadcasting channel. Therefore, a better equalizer that has a rapid convergent speed even in a highly distorted communication environment and is efficient at dealing with distortion even in a data duration without the training symbol being inserted is required.

SUMMARY OF THE INVENTION

In order to solve the above described problem, the present invention provides a fast Kalman-Viterbi joint channel equalizer instead of a conventional equalizer using an LMS algorithm.

An equalizer according to one aspect of the present invention comprises:

a forward filter and a backward filter for receiving an input signal and a predetermined signal and performing filtering to the signals;

a Viterbi decoder for correcting errors during a transmission procedure in a blind mode;

a training symbol storing block for storing training symbols;

a switching block for classifying an output signal of the Viterbi decoder and symbols in accordance with a training mode and a blind mode, and inputting the output signal of the Viterbi decoder and symbols into the backward filter;

a Kalman gain calculating block for receiving input signals of the forward filter and the backward filter and calculating a Kalman gain;

an error signal calculating block for calculating an error signal by comparing an equalized signal, symbols, and the output signal of the Viterbi decoder with one another; and

a tap coefficient updating block for updating a tap coefficient of the filters by using the calculated error signal and the Kalman gain.

The equalizer of the present invention uses a fast Kalman algorithm, which is a kind of a fast adaptive equalizing algorithm, so as to solve a problem of the slow convergent speed of a conventional LMS equalizer. In order to minimize a feedback decision error in a blind period, the equalizer of the present invention performs a soft-decision by using a Viterbi algorithm instead of performing a hard-decision of the output signal in a forward filter or a backward filter. An algorithm on a Kalman equalizer is introduced in an article in IBM journal Re. Dev., vol 18, pp. 267-273, May, 1980, entitled “Channel Equalization Using a Kalman Filter for Fast Data Transmission” by D. N. Godard. A fast Kalman algorithm is introduced in articles in IEEE Trans. Comm., vol. COM-26, pp. 1439-1446, October, entitled “Application of Fast Kalman Estimation to Adaptive Equalization” by D. D. Falconer et al. and in an IEEE Trans. Acoust., Speech, Signal Processing, vol. ASSP-31, pp 1394-1402, entitled “A Fast Sequential Algorithm for Least-Squares Filtering and Prediction” by G. Carayannis et al. A Viterbi algorithm is introduced in an article in IEEE Trans. Inform. Theory, vol. IT-13, pp. 260-269, April, entitled “Error Bounds for Convolutional Codes and an Asymptotically Optimum Decoding Algorithm” by A. J. Viterbi.

The equalizer of the present invention operates in two kinds of modes, a training mode and a blind mode. In the training mode, a transmitting part transmits a training symbol, which is previously perceived by a receiving part, during a predetermined period for channel equalization. The equalizer compares a signal distorted through transmission of a channel with the above perceived training symbol to determine characteristics of the channel. In a blind mode, when a training symbol does not exist after the training mode, the equalizer performs equalization by using only probability distribution of a signal symbol in a transmitting part and a received data signal. Therefore, it is not easy to solve distortion due to interference of inter-symbols in a blind mode compared to a training mode. The equalizer of the present invention is illustrated in FIG. 3. The equalizer has characteristics in that it comprises a forward filter and a backward filter for receiving an input signal and a predetermined signal, and it performs filtering to the signals; a Viterbi decoder for correcting errors during a transmission procedure in a blind mode; a training symbol storing block for storing training symbols; a switching block for classifying an output signal of the Viterbi decoder and symbols in accordance with a training mode and a blind mode and inputting the output signal of the Viterbi decoder and symbols into the backward filter; a Kalman gain calculating block for receiving input signals of the forward filter and the backward filter and calculating a Kalman gain; an error signal calculating block for calculating an error signal by comparing an equalized signal, symbols, and the output signal of the Viterbi decoder with one another; and a tap coefficient updating block for updating a tap coefficient of the filters by using the calculated error signal and the Kalman gain. The present invention also has characteristics in that the equalizer according to the present invention updates a coefficient of filters by using a fast Kalman algorithm while a conventional equalizer updates the coefficient of filters by using an LMS algorithm. Further, the equalizer according to the present invention removes transmission error in a blind mode by using a Viterbi decoder instead of a quantization block.

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate an embodiment of the invention, and together with the description, serve to explain the principles of the invention:

FIG. 1 illustrates a schematic block diagram of a conventional VSB signal receiving system.

FIG. 2 illustrates a structure of an ATSC standard equalizer.

FIG. 3 illustrates a block diagram of a Kalman-Viterbi joint channel equalizer according to an embodiment of the present invention.

FIG. 4 illustrates a procedure for calculating Euclidian distance of a Viterbi decoding algorithm and searching a life path.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

In the following detailed description, only the preferred embodiment of the invention has been shown and described, simply by way of illustration of the best mode contemplated by the inventor(s) of carrying out the invention. As will be realized, the invention is capable of modification in various obvious respects, all without departing from the invention. Accordingly, the drawings and description are to be regarded as illustrative in nature, and not restrictive.

At first, a fast Kalman algorithm will be described by referring to Falconer's paper in the following.

Various kinds of signals, filter coefficients, and other variables may be defined as below.

-   x_(N)(n): input signal vector for overall filters -   y(n): forward filter input signal sample -   d(n): desired signal -   x_(N)(n)=[y(n−1), . . . y(n−N₁)|d(n) . . . d(n−N₂)]^(T) -   ξ_(p)(n)=[y(n)d(n)]^(T) -   ρ_(p)(n)=[y(n−N₁)d(n−N₂)]^(T) -   ε_(p)(n): forward preceding error -   ε_(p)(n)′: forward following error -   A_(Np)(n): forward prediction coefficient matrix -   E_(pp)(n): forward sum error -   η_(p)(n): backward prediction error -   k_(N)(n): Kalman gain -   D_(Np)(n): backward prediction coefficient matrix -   C_(N)(n): tap coefficient for overall filters

When computation starts, the forward preceding error, forward following error, forward prediction coefficient matrix, and forward sum error are evaluated by using the following Equation 2. ε_(p)(n)=ξ(n)+A _(Np)(n−1)^(T) x _(N)(n) A _(Np)(n)=A _(Np)(n−1)−k _(N)(n)ε_(p)(n)^(T) ε_(p)(n)′=ξ_(p)(n)+A _(Np)(n)^(T) x _(N)(n) E _(pp)(n)=λE _(pp)(n−1)+ε_(p)(n)′ε_(p)(n)^(T)  [Equation 2]

When we obtain the forward preceding error, forward following error, forward prediction coefficient matrix, and forward sum error, the Kalman gain may be evaluated through the following Equation 3 by using the above results. $\begin{matrix} {{{{{\overset{\_}{k}}_{M}(n)} = {S_{MM}\left\lbrack \frac{{E_{pp}(n)}^{- 1}{ɛ_{p}(n)}^{\prime}}{{k_{N}(n)} + {{A_{Np}(n)}{E_{pp}(n)}^{- 1}{ɛ_{p}(n)}^{\prime}}} \right\rbrack}}{Q_{MM}{{\overset{\_}{k}}_{M}(n)}} = \left( \frac{m_{N}(n)}{\mu_{p}(n)} \right)}{{\eta_{p}(n)} = {{\rho_{p}(n)} + {{D_{Np}\left( {n - 1} \right)}^{T}{x_{N}\left( {n + 1} \right)}}}}{{D_{Np}(n)} = {\left\lbrack {{D_{Np}\left( {n - 1} \right)} - {{m_{N}(n)}{\eta_{p}(n)}^{T}}} \right\rbrack\left\lbrack {I_{pp} - {{\mu_{p}(n)}{\eta_{p}(n)}^{T}}} \right\rbrack}^{- 1}}{{k_{N}\left( {n + 1} \right)} = {{m_{N}(n)} - {{D_{Np}(n)}{\mu_{p}(n)}}}}} & \left\lbrack {{Equation}\quad 3} \right\rbrack \end{matrix}$

The S_(MM) and Q_(MM) in equation 3 have operations as below. ${{When}\quad{x_{N}(n)}} = {{\left\lbrack \frac{\begin{matrix} {y\left( {n - 1} \right)} \\ {y\left( {n - 2} \right)} \\ \vdots \\ {y\left( {n - N_{1}} \right)} \end{matrix}}{\begin{matrix} {d\left( {n - 1} \right)} \\ {d\left( {n - 2} \right)} \\ \vdots \\ {d\left( {n - N_{2}} \right)} \end{matrix}} \right\rbrack\quad{and}\quad{{\overset{\_}{x}}_{M}(n)}} = {\left\lbrack \frac{\frac{y(n)}{\begin{matrix} {y\left( {n - 1} \right)} \\ \vdots \\ {y\left( {n - N_{1}} \right)} \end{matrix}}}{\frac{d(n)}{\begin{matrix} {d\left( {n - 1} \right)} \\ \vdots \\ {d\left( {n - N_{2}} \right)} \end{matrix}}} \right\rbrack\quad{are}\quad{given}}}$ above, the following relationship may come into existence. ${{S_{MM}{{\overset{\_}{x}}_{M}(n)}} = \left\lbrack \frac{\xi_{p}(n)}{x_{N}(n)} \right\rbrack},{{Q_{MM}{{\overset{\_}{x}}_{M}(n)}} = \left\lbrack \frac{x_{N}\left( {n + 1} \right)}{\rho_{p}(n)} \right\rbrack}$

A Viterbi decoder is a kind of a maximum likelihood decoder that is used for decoding bit streams having coded information in a communication system. When an actually transmitted value provided from the exterior of the decoder is estimated on the basis of a state metric which is an observation value passing through a communication channel, the Viterbi decode determines a maximum likelihood state metric value, which makes a relevant probability maximum with respect to an actually transmitted value and an observation value, as an estimation value with respect to the actually transmitted value. The Viterbi decoder stores a life path into a path memory, and then decodes a symbol by tracing back the path memory on the basis of the state metric. When symbols to be decoded are sequentially inputted into the decoder and at the same time all of the life paths are inputted in the initial stage, the Viterbi decoder traces back the path memory in units of one time tracing, and decodes the following symbol.

The present invention has been conceived to improve the convergent speed and reduce residual error by combining a fast Kalman algorithm into the Viterbi decoder. As one embodiment of such an application, the present invention provides a method for improving equalization performance in an 8-VSB system, which is a North American type ground wave digital television standard.

A Kalman-Viterbi joint channel equalizer according to the present invention is illustrated in FIG. 3.

As shown in FIG. 3, the Kalman-Viterbi joint channel equalizer comprises a forward filter 311, a backward filter 312, a Viterbi decoder 313, a training symbol storing block 314, a switching block 315, a Kalman gain calculating block 316, an error signal calculating block 317, and a tap coefficient updating block 318.

Output signals of the filters 311 and 312 may be represented as in the following Equation 4. $\begin{matrix} {{y\lbrack n\rbrack} = {{\sum\limits_{i = 0}^{N_{h} - 1}\quad{{b_{i}\lbrack n\rbrack}{x\left\lbrack {n - i} \right\rbrack}}} + {\sum\limits_{j = 1}^{N_{a}}\quad{{a_{j}\lbrack n\rbrack}{\hat{d}\left\lbrack {n - j} \right\rbrack}}}}} & \left\lbrack {{Equation}\quad 4} \right\rbrack \end{matrix}$

In the above Equation 4, x[n] is an input signal of the filters 311 and 312 at time n, y[n] is an output signal of the filters 311 and 312 at time n, b_(i)[n] is a tap coefficient of the forward filter 311 at time n, a_(i)[n] is a tap coefficient of the backward filter 312 at time n, N_(b) is a tap number of the forward filter 311, N_(a) is a tap number of the backward filter 312, and {circumflex over (d)}[n] is a training symbol in case of a training mode while being an output signal of the Viterbi decoder in case of a blind mode.

As can be seen from the above Equation 4, the forward filter 311 sequentially delays digital input data x[n] sampled at a bit rate of 10.76 MHz, multiplies the digital input data x[n] by b_(i)[n] sequentially, and adds each result of the multiplication to output equalized data. Then, the backward filter 312 has the same operation as the forward filter 311, excepting that input of the backward filter 312 is a training symbol or an output signal of the Viterbi decoder. While performing these operations periodically, the filters 311 and 312 adjust tap coefficients to optimal values on the basis of the information inputted from the tap coefficient updating block 318, and perform filtering to the input signal, thereby obtaining desired output data. At this time, the forward filter 311 performs filtering to symbols inputted from the exterior of the decoder, and removes interference between the exterior signals. The backward filter 312 performs filtering by using a previously detected value so as to remove an interference signal of the present symbol, which is induced by the previously detected symbol.

The switching block 315 determines a training mode or a blind mode. In case of the training mode, the switching block 315 outputs training symbols from the training symbol storing block 314. In case of the blind mode, the switching block 315 uses the output of the Viterbi decoder 313 instead of a simple quantizer used as a symbol detector in a conventional equalizer. The Viterbi decoder 313 starts to operate in the blind mode right after the training mode. The Viterbi decoder 313 receives output of the filters 311 and 312, and corrects a decision error of a transmission signal by performing a soft-decision. Therefore, the convergent speed in the blind mode may be improved. At this time, the Viterbi decoder 313 performs decoding by using a method for selecting a minimum distance among Euclidian distances.

FIG. 4 illustrates an example of the Viterbi decoding algorithm. As shown in Equation 3, the computation amount increases in a fast Kalman algorithm when the number of additionally inputted data and outputted data increase. Therefore, it is required that the tracing back length is minimized in the Viterbi decoder in order to reduce the computation amount. When a fast Kalman algorithm is applied to a DFE, the multiplication computation amount may be represented as in the following Equation 5. Computation Amount: 7Np+Np ²+3p²+2N+(4/3)p ³ −p/3 p=2*(1+trace_back_len*12)  [Equation 5]

-   N: number of equalizer taps -   p: number of additional data inputted from a fast Kalman algorithm -   trace_back_len: tracing back length at Viterbi decoder

Accordingly, the shorter the tracing back length becomes, the less the multiplication computation amount of the algorithm used in the blind mode becomes. It is possible to obtain a more accurate value by increasing the tracing back length. When the computation amount decreases or the decoding delay value is long as in a digital broadcasting system using twelve TCM coders, the tracing back length is set to “1” to decrease the delay value, and hence the multiplication computation amount of the equalizer used in the blind mode may decrease. Through application of the above method, hardware complexity may be reduced by 1/state as compared with a PSP (per-survivor processing) algorithm which is a conventional equalizing method. In addition, a problem that the PSP algorithm does not remove pre-echo may be solved.

The error signal calculating block 317 receives an equalized signal and training symbol or output of the Viterbi decoder, and then calculates an error signal through the following Equation 6. e(n+1)=d(n+1)−C _(N)(n)^(T) x _(N)(n+1)  [Equation 6]

The Kalman gain calculating block 316 receives input signals of the forward filter 311 and the backward filter 312, and calculates Kalman gain by using the Equations 2 and 3. Then, the Kalman gain calculating block 316 transmits the calculated Kalman gain into the tap coefficient updating block 318, which performs tap coefficient updating by using the above error signal and the Kalman gain, and transmits the tap coefficient into each of the filters 311 and 312. An equation for updating of tap coefficients is shown in the following Equation 7. C _(N)(n+1)=C _(N)(n)+k _(N)(n+1)e(n+1)  [Equation 7]

The tap coefficient updating block 318 transmits a tap coefficient determined by the above Equation 7 into each of the filter 311 and 312.

When channel equalization has been finished at time index n through the above described procedure, the time index n is incremented by “1” The channel equalization is performed by repeating the above procedure.

According to the present invention, the fast Kalman-Viterbi joint channel equalizer may improve reception performance of an N level VSB digital television under a dynamic multi-path environment.

While this invention has been described in connection with what is presently considered to be the most practical and preferred embodiment, it is to be understood that the invention is not limited to the disclosed embodiments, but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims. For example, all the possible equalizing algorithms such as a traditional Kalman and RLS algorithm, a fast RLS (recursive least squares), or an LMS system may be applied to the equalizer of the present invention. Therefore, it will be obvious for those skilled in the art to change, alter, or adjust the disclosed embodiments without departing from the spirit and scope of the invention. Although the present invention has been described and illustrated in detail, it is clearly understood that the same is for illustration and example only, and is not to be taken as limitation, the spirit and scope of the present invention being limited only by the terms of the appended claims. 

1. A Kalman-Viterbi joint channel equalizer, comprising: a forward filter and a backward filter for receiving an input signal and a predetermined signal and performing filtering to the signals; a Viterbi decoder for correcting errors during a transmission procedure in a blind mode; a training symbol storing block for storing training symbols; a switching block for classifying an output signal of the Viterbi decoder and symbols in accordance with a training mode and a blind mode, and inputting the output signal of the Viterbi decoder and symbols into the backward filter; a Kalman gain calculating block for receiving input signals of the forward filter and the backward filter and calculating a Kalman gain; an error signal calculating block for calculating an error signal by comparing an equalized signal, symbols, and the output signal of the Viterbi decoder with one another; and a tap coefficient updating block for updating a tap coefficient of the filters by using the calculated error signal and the Kalman gain.
 2. The Kalman-Viterbi joint channel equalizer according to claim 1, wherein the Kalman gain calculating block updates the tap coefficient by applying a fast Kalman algorithm in a blind mode.
 3. The Kalman-Viterbi joint channel equalizer according to claim 2, wherein the Viterbi decoder uses a Viterbi decoding algorithm in a blind mode.
 4. The Kalman-Viterbi joint channel equalizer according to any one of claims 1 to 3, wherein the Viterbi decoder reduces a tracing back length to use the reduced tracing back length in obtaining errors for tap coefficient updating.
 5. The Kalman-Viterbi joint channel equalizer according to any one of claims 1 to 3, wherein the Viterbi decoder corrects errors by skipping symbols in a predetermined number of symbols to obtain errors for tap coefficient updating.
 6. The Kalman-Viterbi joint channel equalizer according to any one of claims 1 to 3, wherein a symbol location of a robust stream is previously recognized and is applied to a data duration blind algorithm using the Viterbi decoder when an E-VSB is applied to the Kalman-Viterbi joint channel equalizer.
 7. A VSB signal receiving system, comprising: a tuner for receiving an RF signal from an antenna and synchronizing the RF signal with a local oscillation signal to transform the RF signal into an IF signal; an NTSC removing filter for removing an NTSC component from the IF signal to prevent degradation of an HDTV due to the NTSC component; an equalizer for removing multi-path distortion generated in a transmission channel by equalizing the input signal; a phase tracer for removing phase noise from the equalized signal; a trellis decoder for performing trellis decoding with respect to an output signal of the phase tracer and outputting a decoded signal; a data de-interleaver for performing reverse interleaving to the decoded signal; an RS decoder for performing Reed-Solomon decoding to the output signal of the data de-interleaver so as to generate error-corrected bit streams; and a de-randoinizer for providing the output.signal of the RS decoder to other elements of the VSB signal receiving system, wherein the equalizer further comprises: a forward filter and a backward filter for receiving an input signal and a predetermined signal and performing filtering to the signals; a Viterbi decoder for correcting errors during a transmission procedure in a blind mode; a training symbol storing block for storing training symbols; a switching block for classifying the output signal of the Viterbi decoder and symbols in accordance with a training mode and a blind mode and inputting the output signal of the Viterbi decoder and symbols into the backward filter; a Kalman gain calculating block for receiving input signals of the forward filter and the backward filter and calculating a Kalman gain; an error signal calculating block for calculating an error signal by comparing an equalized signal, symbols, and the output signal of the Viterbi decoder with one another; and a tap coefficient updating block for updating a tap coefficient of the filters by using the calculated error signal and the Kalman gain. 